GR 98 P 8110 

PROGRAM -CONTROLLED UNIT 

5 Cross-Ref erence to Related Application : 

This application is a continuation of copending International 
Application No. PCT/DE99/01988 , filed July 1, 1999, which 
designated the United States. 

flO Background of the Invention : 
f; Field of the Invention : 

H The invention lies in the computer technology field and 

pertains, more specifically, to a program- controlled unit with 
3 one or more application-specif ically configurable, intelligent 
,=15 interfaces. 

Program- control led units are devices controlled by software 
programs, that is to say microprocessors, microcontrollers or 
the like. They exist in a multiplicity of diverse embodiments 
20 and need not be described in specific detail. 

Even though microprocessors, microcontrollers and the like can 
be obtained in a wide variety of embodiments (or perhaps 
precisely because of this) , it is difficult or sometimes even 
25 impossible to find one type which can satisfy the requirements 
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imposed in the specific individual case (and as far as 
possible only these requirements) . 



This is particularly applicable to microcontrollers because 
5 after all, if possible, all the peripherals (analog/digital 
converter, digital/analog converter, timer, interrupt 
controller, etc.) required for the relevant application are 
intended to be integrated in the microcontrollers. 

■Jio If the microcontroller selected for the relevant application 
m is one which - for whatever reason - cannot satisfy all of the 
|y requirements imposed, then this generally means that the 
= hardware within which the microcontroller is intended to be 

}f=J used becomes more complex. This turns out to be particularly 
j^l5 difficult and complex in the case of microcontrollers because 

the latter are not designed to cooperate with coprocessors and 

the like. 



On the other hand, if the microcontroller selected for the 
20 relevant application is one which can do more than is 
required, then the price of the product containing the 
microcontroller generally rises as a result. Added to this is 
the fact that often the operation of the microcontroller also 
becomes more complex and more complicated. This is because the 
25 unrequired peripheral units of the microcontroller also have 
to be taken into account during the system development and be 
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controlled as intended by the intelligent core of the 
microcontroller (the so-called microprocessor core or jaP core) 
which processes the instructions to be executed. 

5 Summary of the Invention : 

It is accordingly an object of the invention to provide a 
program-controlled unit, which overcomes the above-mentioned 
disadvantages of the heretofore-known devices and methods of 
,3 this general type and which provides for a program-controlled 
IfllO unit that can be used optimally in each case for a large 
m number of highly varied applications. 

]^ With the foregoing and other objects in view there is 
Jf; provided, in accordance with the invention, a program- 
d^lB controlled unit with one or more application-specif ically 
configurable intelligent interfaces, comprising: 

an intelligent core configured to process instructions to be 
executed; 

a plurality of units selected from the group consisting of 
2 0 internal peripheral units disposed inside the program- 
controlled unit, external peripheral units exterior to the 
program- control led unit, and one or more memory devices; 

a structurable hairdware unit selectively forming an 
application-specif ically configurable intelligent interface 
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for respectively connecting the intelligent core and the 
units, including an interface connection between the 
intelligent core and the internal peripheral units, between 
the intelligent core and the external peripheral units, 
5 between the intelligent core and the memory devices, and 
between the plurality of units; and 

wherein the structurable hardware unit is configured to 
evaluate and process data and/or signals received thereby. 

Alternatively, or in addition, the structurable hardware unit 
is configured to inject instructions into an instruction 
pipeline of the intelligent core. 

In another alternative, or in addition, the structurable 
H 15 hardware unit is configured to generate and to output 
interrupt requests and/or event -signaling messages. 

Finally, in a further alternative, the structurable hardware 
unit is configured to selectively react to interrupt requests 
2 0 or other event -signaling messages from devices connected 
thereto and prevent the interrupt requests or the event - 
signaling messages from being forwarded. 

In sum, the program-controlled unit comprises one or more 
25 application-specif ically configurable intelligent interfaces. 
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Given appropriate configuration, such interfaces can to the 
greatest possible extent independently ensure that the 
intelligent core and one or more peripheral units and/or the 
5 intelligent core and one or more memory devices and/or two or 
more peripheral units themselves and/or one or more peripheral 
units and one or more memory devices cooperate as desired with 
minimal loading of the intelligent core. 

0 In accordance with an added feature of the invention, the 
structurable hardware unit is disposed in circuit terms 
between the intelligent core and the plurality of units. 

In accordance with an additional feature of the invention, the 
5 structurable hardware unit is connected to a multiplicity of 
potential data and signal sources and data and signal 
destinations^ and a plurality of multiplexers are connected to 
the structurable hardware unit for selecting current data and 
signal sources and current data and signal destinations. 

0 

In accordance with another feature of the invention, the data 
and signal sources and the data and signal destinations 
comprise the intelligent core, the peripheral units, the 
memory devices, and/or portions of the structurable hardware 
5 unit itself. 
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In accordance with a further feature of the invention, the 
structuring of the structurable hardware unit selectively 
results in an alteration of given data paths and/or in a 
configuration of logic elements. 

5 

In accordance with again an added feature of the invention, 
the structurable hardware unit comprises a clock generation 
unit generating a clock signal and a logic block unit 
connected to receive the clock signal^ the logic block unit 
0 enabling devices to be connected via the structurable hardware 
unit to cooperate as desired. 

In accordance with again an additional feature of the 
invention, the clock generation unit and the logic block unit 
5 each contain configurable elements. 

In accordance with again another feature of the invention, the 
clock generation unit is formed at least in part by a DNF 
logic configuration, a NAND array, a multiplexer-based logic 
0 variant, and/or a structurable logic configuration. 

In accordance with again a further feature of the invention, 
the logic block unit is formed at least in part by a DNF logic 
configuration, a NAND array, a multiplexer-based logic 
5 variant, and/or a structurable logic configuration. 
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In accordance with yet an added feature of the invention, the 
logic block unit comprises at least one logic block subdivided 
at least partly into individually configurable sub-blocks with 
predetermined tasks. Preferably, one of the sub-blocks is 

5 configured as a processing device enabled for arithmetic 

and/or logical processing of data input to the sub-block. It 
is also possible for one of the sub-blocks to be configured as 
a state machine for central sequence control. Similarly, one 
of the sub-blocks may be configured as an address calculation 

0 device for calculating source and destination addresses. Also, 
it is possible for one of the sub-blocks to be configured as 
an instruction injection device for injecting instructions 
into the instr-uction pipeline of the intelligent core. 

5 In accordance with yet an additional feature of the invention, 
the structurable hardware unit is configurable with fuses 
and/or anti- fuses. 

In accordance with yet another feature of the invention, the 
0 structurable hardware unit is reversibly configurable. In a 
preferred embodiment, the structurable hardware unit is 
configurable based on data representing a desired 
configuration, and the data are stored in memory devices 
insert ible into a memory or I/O area which is addressible by 
5 the intelligent core. 
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In accordance with yet a further feature of the invention, the 
structurable hardware unit is enabled for reconfiguration only 
at predetermined times. 

5 In accordance with a concomitant feature of the invention, the 
structurable hardware unit is enabled for reconfiguration at 
any time. 

If the interfaces are made in such a way that they are 
reconf igurable during entirely normal operation of the 
program- controlled unit, then the program-controlled unit can 
even be reconfigured dynamically. 

Consequently, a program-controlled unit has been created which 
can be used optimally in each case for a large number of 
highly varied applications. 

Other features which are considered as characteristic for the 
invention are set forth in the appended claims. 
20 

Although the invention is illustrated and described herein as 
embodied in a program-controlled unit, it is nevertheless not 
intended to be limited to the details shown, since various 
modifications and structural changes may be made therein 
25 without departing from the spirit of the invention and within 
the scope and range of equivalents of the claims. 
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The construction and method of operation of the invention, 
however, together with additional objects and advantages 
thereof will be best understood from the following description 
5 of specific embodiments when read in connection with the 
accompanying drawings . 

Brief Description of the Drawings : 

Fig. 1 is a schematic illustration of the construction of the 
]H-0 program- control led unit according to the inventions- 
Fig. 2 is a schematic illustration of the construction of an 
SLE layer 12 of the program- control led unit in accordance with 
Fig. 1; 

Fig. 3 is a schematic diagram of the construction of a clock 
generation unit 121 of the SLE layer 12 in accordance with 
Fig. 2; 

2 0 Fig. 4 is a schematic diagram of the construction of a logic 
block unit 122 of the SLE layer 12 in accordance with Fig. 2; 
and 

Fig. 5 is a schematic diagram illustrating the configuration 
25 of the logic block unit 122 in accordance with Fig. 4 for a 
practical example. 
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Description of the Preferred Embodiments : 

The exemplary program- control led unit described in more detail 
below is a microcontroller, it will be understood, however, 
5 that the program-controlled unit can, in principle, also be 
any other program-controlled unit, such as a microprocessor 
for example . 

The microcontroller considered herein is designated by the 
reference symbol 1 in the figures. It is distinguished by the 
fact that it comprises one or more application-specif ically 
configurable intelligent interfaces . 

The novel microcontroller construction is referred to below as 
application-specif ically structurable controller architecture 
or ASSC architecture. 

The general structure of a microcontroller having the ASSC 
architecture is schematically illustrated in Fig. 1. 
20 

Referring now to the figures of the drawing in detail and 
first, particularly, to Fig. 1 thereof, there is shown an 
intelligent core 11, which is usually referred to as 
microprocessor core or |iiP core and processes the instructions 
25 to be executed, a so-called SLE layer 12 and also peripheral 
units 13 to 19, the peripheral units, for their part, 
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comprising a serial interface unit 13, a parallel interface 
unit 14, an analog/digital converter 15, a digital/analog 
converter IS ^ a timer 17, an interrupt controller 18 and, if 
appropriate, further peripheral units 19. Furthermore, an 
5 external random access memory (RAM) 2 and an external read- 
only memory (ROM) 3 are provided; the RAM 2 and the ROM 3 can 
also be realized as internal memories without any difficulty. 

The SLE layer 12 is arranged in circuit terms between the juP 
^SlO core 11, peripheral units (for example the peripheral units 13 
m to 19) provided inside and/or outside the program-controlled 
uJ unit, and/or memory devices (for example the RAM 2 and/or the 
;^ ROM 3) . It contains structurable data paths and/or logic 
Jjf elements which can be structured or configured in such a way 
;^15 that the SLE layer 12 can be used as the at least one 
application-specif ically configurable interface, more 
precisely as a configurable intelligent interface between the 
jiP core and one or more peripheral units and/or between the ]xP 
core and one or more memory devices and/or between two or more 
2 0 peripheral units themselves and/or between one or more 
peripheral units and one or more memory devices. 

Within the SLE layer 12 there are preferably both direct 
connections and configurable data paths and data path linkages 
2 5 between the devices which are connected or can be connected 
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via the SLE layer; the effect achieved by the direct 
connections is that the novel microcontroller can also be 
utilized like a conventional microcontroller (not having an 
SLE layer 12) . 

5 

If the SLE layer 12 has access to memory devices (for example 
to the RAM 2 and/or to the ROM 3) it can transfer data from 
and to the memory devices independently, i.e. without the 
participation of the jiiP core, for itself and/or the |iP core 

iqLO and/or the peripheral units. As a result, data transfers can 

^^ij be carried out more rapidly and without burdening the \xF core 
11. In this case, the SLE layer 12 is designed in such a way 

=3 that it can identify and handle contending accesses to memory 

i|j devices. 

315 

The SLE layer 12 can also be constructed without an interface 
to the memory devices present. In that case, the SLE layer and 
the [iV core are preferably designed in such a way that the SLE 
layer can inject into the \iP core (more precisely into the 
2 0 instruction pipeline thereof) instructions which can cause the 
fO-P core to carry out data transfers required by the SLE layer 
and/or the peripheral units. 
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The basic construction of the SLE layer 12 is illustrated in 
Fig. 2. The SLE layer 12 comprises a clock generation unit 121 
and a logic block unit 122 . 

5 The clock generation unit 121 serves for supplying the logic 
block unit 122 with one or more different clock signals OUTCLK 
generated on the basis of one or more master clock signals 
INCLK, By way of example, clock signals having an altered 
_ frequency, altered duty ratio and/or altered phase angle 
^-Slo relative to the master clock signal or signals INCLK are 
Jf^ generated in the clock generation unit 121. 

In the example considered, the clock generation unit 121 
comprises a fast configurable logic arrangement, for example a 
^^15 so-called DNF logic arrangement (NOT-AND-OR logic) , suitable 
for the practical realization of a disjunctive normal form, 
with downstream configurable storage, inversion/buffering and 
feedback. A two- stage DNF architecture (having two DNF blocks) 
is used in the example considered. 

20 

The fundamental construction of a clock generation unit 121 
which generates an output clock signal OUTCLK on the basis of 
a master clock signal INCLK (for example the CPU clock signal) 
is illustrated in Fig. 3, The customary form of representation 
2 5 for PALs (programmable array logic) and GALs (Generic array 
logic) has been chosen; transparent nodes represent 
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configurable connections, and filled-in (black) nodes 
represent permanent connections. 

In the example considered, the clock generation unit 121 
comprises two identically constructed DNF blocks DNFl and 
DNF2, the first DNF block DNFl representing a first DNF logic 
stage and comprising AND elements Al, an OR element Ol, a 
flip-flop FFl (clocked by the master clock signal) , and a 
multiplexer MUXl , and the second DNF block DNF2 representing a 
second DNF logic stage and comprising AND elements A2 , an OR 
element 02, a flip-flop FF2 (clocked by the master clock 
signal), and a multiplexer MUX2 . The two DNF blocks DNFl and 
DNF2 are supplied with the same input signals. In the example 
considered, the input signals comprise the master clock signal 
INCLK, the inverted master clock signal /INCLK, an output 
signal OUTl of the first DNF block DNFl, the inverse output 
signal /OUTl , an output signal OUT2 of the second DNF block 
DNF2, and the inverse output signal /0UT2 . The output signal 
0UT2 of the second DNF block DNF2 and the inverse output 
signal /0UT2 are fed to a multiplexer MUX3, and the output 
signal thereof is output via a driver T2 as the output clock 
signal OUTCLK to be generated. 

The input signals, more precisely signal combinations which 
can be selected via configurable connections, applied to the 
respective DNF blocks DNFl and DNF2 are applied to the AND 
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elements Al and A2 of the respective DNF blocks. The output 
signals of the AND elements Al and A2 are fed to the OR 
elements 01 and 02, respectively, or used as a reset signal 
ASR for asynchronously resetting the flip-flops FFl and FF2 , 
5 respectively. The output signals of the OR elements Ol and 02 
are used as input signals of the flip-flops FFl and FF2 , 
respectively; they (the output signals of the OR elements 01 
and 02) and the inverse output signals are additionally 
applied to the multiplexers MUXl and MUX2 , respectively. The 
j|.0 output signals and the inverse output signals of the flip- 
:Z flops FFl and FF2 are likewise applied as input signals to the 
= 71 multiplexers MUXl and MUX2 , respectively. The output signal 

and the inverse output signal of the multiplexers MUXl and 
m MUX2 are the output signals OUTl, /OUTl, 0UT2 and /0UT2 , 
14-15 already mentioned above, of the two DNF blocks of the clock 
'^"^ generation unit 121. 



Such a construction, or a similar construction, of the clock 
generation unit 121 allows the generation of a multiplicity of 
20 clock variations; the feedback of (internal) signals (the 

signals OUTl , /OUTl, OUT2 , /OUT2 in the example considered) 
generated within the clock generation unit 121 also makes it 
possible to realize non-binary duty and division ratios. 



25 The arrangement shown in Fig. 3 is only a simple example for 
explaining the fundamental construction of the clock 
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generation unit 121. In practice, the number of clock signals 
generated by the clock generation unit 121 should not be less 
than four. The lower limit for the possible number of terms 
per DNF should likewise be four. For each generated clock 
5 signal, at least one internal signal should be generated and 
be provided like the internal signals OUTl, /OUTl, OUT2 and 
/0UT2, for example, as a possible basis for the clock signal 
generation . 

The clock generation unit 121 need not necessarily be 
constructed using a two-stage DNF logic arrangement. The DNF 
logic arrangement used may also have fewer stages (that is to 
T say just one stage) or arbitrarily many more stages. 

Instead of the DNF logic arrangement, it is also possible to 
use another structurable logic arrangement, for example MAND 
arrays or multiplexer-based variants. 



The logic block unit 122 already mentioned above is the actual 
20 core of the SLE layer 12. Like the clock generation unit 121, 
it may comprise a structurable logic arrangement suitable for 
the practical realization of the disjunctive normal form, or 
one of the alternatives mentioned. Virtually any desired 
linkages, processing and evaluations of the input signals can 
25 be carried out by means of such universally usable 
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structurable logic arrangements. A logic block unit 122 of 
this type is extremely flexible. 



In the example considered in the present case, the logic block 
5 unit 122 has been realized differently: it contains one or 
more logic blocks which are subdivided at least partly into 
sub-blocks with predetermined tasks. This simplifies the 
complexity of the gates used but hardly reduces the 
flexibility of the SLE layer 12 - at any rate given a suitable 
:y.O definition of the sub-blocks and corresponding cross- 
connections between the individual sub-blocks. 

= The fundamental construction of a logic block subdivided into 

Id various sub-blocks is illustrated in Fig. 4. The logic block 
I^S shown therein comprises four sub-blocks, namely 

■ a first sub-block 5 for the inputting and/or outputting of 
data and/or signals and the processing thereof, 

2 0 "a second sub-block 6 for central sequence control for the 
operations proceeding within the relevant logic block, 

■ a third sub-block 7 for address calculations, and 

25 ■ a fourth sub-block 8 for instruction injections into the . 
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In the example considered, the sub-blocks comprise 
configurable multiplexers (for switching data paths as 
desired), registers (for buffer-storing data and/or coded 
5 states) and structurable logic (for linking data and/or 

signals with one another and with constants and for coding and 
decoding states) . 

In the example considered, the first sub-block 5 serves for 
linking input data and/or signals with one another or with 

IZ constants; in the example considered, it comprises a first 

multiplexer 51, a second multiplexer 52, a constant register 
53, a first structurable logic arrangement 54, a second 

M structurable logic arrangement 55, and a register 56. 

fa5 

Data and/or signals switched through by the first multiplexer 
51 are linked with one another or with constants stored in the 
constant register 53 by the structurable logic arrangements 54 
and 55 and output via the second multiplexer 52. The register 

20 56 provided between the structurable logic arrangements 54 and 
55 serves as a buffer store which can be used, for example, 
for buffer-storing data that are to be linked until the other 
data with which they are to be linked are valid; the data 
and/or signals output by the structurable logic arrangement 54 

25 can alternatively be transmitted via a bypass directly 
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(without a detour via the register 56) to the structurable 
logic arrangement 55. 

The multiplexers 51 (source selection) and 52 (destination 
selection) connect the first sub-block 5 to different data 
and/or signal sources and data and/or signal destinations. 
Data and/or signal sources and data and/or signal destinations 
are, in particular, the other sub-blocks, the |aP core 11, 
peripheral units (e.g. the peripheral units 13 to 19) provided 
inside and/or outside the microcontroller, and/or memories 
(e.g. the RAM 2 and/or the ROM 3) . The connection to the 
aforementioned or other data and/or signal sources and data 
and/or signal destinations can be effected via databuses (but 
does not have to be) . 

The first sub-block 5 is operatively comparable with the 
arithmetic logic unit (ALU) of a program-controlled unit 
working according to the Von Neumann Principle. 

In the example considered, the second sub-block is a state 
machine for central sequence control in the relevant logic 
block; in the example considered, it comprises a first 
structurable logic arrangement 61, a second structurable logic 
arrangement 62, a register 63, and a multiplexer 64. 
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It is incumbent upon the structurable logic arrangement 61 to 
determine the respective state of the relevant logic block, in 
particular in a manner dependent on the states, signals and 
signal profiles in or from the clock generation unit 121, the 
other sub-blocks, the |iP core 11, the peripheral units (e.g. 
the peripheral units 13 to 19) and/or the memories (e.g. the 
RAM 2 and/or the ROM 3); the operation which should (must) 
currently proceed in the logic block depends on the respective 
state of said logic block. The aforesaid state, more precisely 
a data value representing it, may be stored in the register 63 
and be decoded as required by the structurable logic 
arrangement 62 . The structurable logic arrangement 62 outputs 
one or more output signals. These output signals are control 
signals based on the respective state of the relevant logic 
block and are output via the multiplexer 64 in particular to 
the other sub-blocks, but also, if appropriate, to the |aP 
core, the peripheral units and/or the memory devices. 

In the example considered, the second sub-block 6 can be used 
to realize different simple automata types (up to Mealy) , to 
be precise also with different clocks. 

The task incumbent upon the second sub-block 6 is comparable 
with the control unit of a Von Neumann CPU, the processing of 
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instructions naturally being omitted (the states are traversed 
in a manner triggered by external signals) . 

In the example considered, the third sub-block 7 serves in 
particular (but not exclusively) for address calculation for 
block-by-block data transfers; in the example considered, it 
comprises an address register 71, a constant register 72, an 
incrementing/ decrementing unit 73, a first structurable logic 
arrangement 74 and a second structurable logic arrangement 75. 

The third sub-block 7 can calculate source and destination 
addresses and output them to the other sub-blocks, the [aP 
core, the peripheral units and/or the memory. 

The present address in each case is stored in the address 
register 71 and can be incremented or decremented by the 
incrementing/decrementing unit 73. The constant register 72 is 
designed to store an end address, and an address comparison 
can be carried out by the structurable logic arrangements (in 
order, for example, to be able to check whether the address 
stored in the address register 71 has reached the end address 
stored in the constant register 72) . 

The provision of this third sub-block 7 is optional and is 
very useful in particular (but not exclusively) when the SLE 
layer 12 has direct access to the memory. 
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In the example considered, the fourth sub-block 8 serves for 

injecting instructions into the pipeline of the ]lxP core 11; in 

the example considered, it comprises a constant register 81 
5 and a structurable logic arrangement 82 . 

Instructions are injected under the control of the second sub- 
block 6, more precisely the control signals output by the 
latter. The instruction code of the instruction to be injected 
So is stored in the constant register 81 and is communicated as 
Z required (if appropriate together with address and data 
Ti information) via the structurable logic arrangement 82 to the 
|LiP core 11; for this purpose, the second sub-block 6 puts the 
M structurable logic arrangement 82, as required, into a state 
as in which the instruction code stored in the constant register 
81 (if appropriate together with the data output from the 
first sub-block 5 and/or the address output from the third 
sub-block 7) is injected into the pipeline of the |aP core. 

2 0 As has already been mentioned or indicated at least in part 
above, there are diverse cross-connections between the 
individual sub-blocks 5 to 8 . The cross-connections depicted 
in Fig. 4 are to be regarded only as examples. The number of 
cross-connections and the beginning and end points thereof 

25 depend in particular on the concrete application of the 
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relevant logic block and the number and function of the sub- 
blocks thereof and may be designed, as required, as 
configurable connections. 

5 The at least partial division of the logic blocks of the logic 
block unit 122 of the SLE layer 12 into sub-blocks enables the 
practical realization of the logic blocks with minimal 
complexity. In particular, considerably fewer linkage 
possibilities have to be provided compared with the 
'^10 realization of the logic block unit using one or more 
H structurable logic arrangements which can be used universally; 
;H the reason for this is that because each sub-block only has to 
perform one precisely defined task, the sub-blocks in each 

O 

\a case have to be able to link only a few signals with one 

^45 another - in contrast to structurable logic arrangements which 

\^ can be used universally. 

The tasks which have to be performed by the respective sub- 
blocks, and the cross-connections between the individual sub- 
2 0 blocks make it possible for the relevant logic blocks to have 
similar performance to that of logic blocks constructed using 
structurable logic arrangements which can be used universally. 

This holds true even when the logic blocks are divided into 
2 5 sub-blocks which are constructed differently and/or have to 
perform different tasks and/or have different cross- 
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connections and/or are provided in a larger or smaller number 
than the sub-blocks 5 to 8 which are used in the example 
considered in the present case and are described with 
reference to Fig. 4. 

5 

In the case of data group operations, it may be necessary to 
additionally integrate memory units into the SLE layer 12. In 
that case, results required for later calculations do not have 
to be swapped into storage devices provided outside the SLE 

O 

^fflO layer 12, but rather can be immediately (buffer-) stored 
H internally within the SLE layer 12 . 

f I 
i = = 

In the example considered, the structurable logic arrangements 
Ij used in the sub-blocks are DNF logic arrangements whose 
i|5 construction essentially corresponds to the construction of 
the DNF logic arrangements used in the clock generation unit 
121; in this case, the input and output signals are not, of 
course, clock signals but rather data and/or control signals, 
and required clock signals (for example for clocking the flip- 
20 flops) are selected from the clock signals generated by the 
clock generation unit 121. 

However, there is no restriction to the effect that the 
structurable logic arrangements of the logic block 122 are 
25 such or* similar DNF logic arrangements; instead, it is also 
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possible to use KTT^ND arrays, multiplexer-based variants or 
other structurable logic arrangements. 

The configuration of the configurable elements of the SLE 
layer, i.e. the configuration of the multiplexers, the 
configurable connections within the structurable logic 
arrangements and the registers can essentially be effected 
like the configuration of the known field-programmable logic 
arrangements (PLAs, GALs, PLDs , FPGAs etc.). 

A first possibility in this respect consists in the 
(irreversible) production or erasure of connections using so- 
called fuses or antifuses. 

Another possibility consists in carrying out reversible 
configuration based on data representing the desired 
configuration, the data being stored in EPROMS, EEPROMS or the 
like provided inside or outside the program-controlled unit. 
As a result, the configuration of the program-controlled unit 
can be changed a limited number of times. 

A further possibility consists in carrying out reversible 
configuration based on data representing the desired 
configuration, but where the data are stored in a RAM or the 
like. As a result, the configuration of the program-controlled 
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unit can be changed an unlimited number of times and very 
rapidly. 

The EPROMs, EEPROMS, RAMs or other memories in which the data 
representing the configuration of the program-controlled unit 
are stored are preferably designed in such a way that they can 
be inserted into the memory or I/O area which can be accessed 
by the i^P core 11. The configuration of the SLE layer 12 can 
then be set as desired by the jaP core 11 itself. 

If the intention is to preclude the situation where the 
operation of the program-controlled unit is disturbed by the 
configuration of the SLE layer 12, provision may be made for 
allowing the configuration only at predetermined points in 
time (for example within a predetermined time after the 
resetting of the program-controlled unit) . 

Given appropriate configuration of the SLE layer 12, the 
latter can be assigned specific tasks which, heretofore, could 
or had to be processed exclusively or to a very great extent 
by the jaP core 11. These tasks include in particular (but not 
exclusively) the preprocessing, postprocessing, evaluation 
and/or control of data and/or signals and also the initiation 
and monitoring of the cooperation of the devices connected via 
the SLE layer 12 . 



GR 98 P 8110 



If the configuration or a reconfiguration of the SLE layer 12 
is permitted at any time, then these tasks can even be swapped 
dynamically into the SLE layer. 

Irrespective of this, that is say even when dynamic 
configuration of the SLE layer 12 is not possible, the loading 
on the |aP core 11 can be considerably relieved by the SLE 
layer 12. This is explained below using a practical example. 

The example relates to analog/digital conversion of data. More 
precisely, suppose that 

■ an A/D converter (for example the A/D converter 15) having a 
conversion width of 8 bits is started by a timer (for 
example by the timer 17) , 

■ the result of the A/D conversion is stored together with a 
12 -bit counting marker, 

■ the result of the A/D conversion is monitored in respect of 
specific limit values being exceeded and undershot, in which 
case branching to a specific routine should be effected when 
the limit values are exceeded or undershot. 
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■ and the operation is terminated after 2048 measurements. 

An application of this type requires a relatively high 
complexity in the case of a purely software-based solution. 
Since a typical A/D converter integrated in a microcontroller 
does not yield the result spontaneously, that is to say works 
as a so-called flash converter and has a conversion time in 
the region of a few microseconds, one of the following paths 
must be taken in connection with the exact execution of the 
application specification : 

1) The timer triggers an interrupt. The interrupt service 
routine starts the A/D conversion and is then ended. The 
A/D converter likewise triggers an interrupt when the 
conversion is ended. The interrupt service routine that is 
thereupon executed causes the A/D conversion result to be 
read out and processed. 

2) The timer triggers an interrupt. In the interrupt service 
routine that is thereupon executed, the A/D conversion is 
started, there is a wait for the end of the conversion, and 
finally (after the end of the conversion) the A/D 
conversion result is read out and processed. 

If the conversion times are shorter than the interrupt latency 
times, the second variant should be preferred. Otherwise, the 
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first variant would be preferable. In general, however, the 
third variant below is the most favorable: 

3) The timer triggers an interrupt. In the interrupt service 
5 routine that is thereupon executed, the last A/D 

conversion result is read out, the next A/D conversion is 
started, and the A/D conversion result that has been read 
out is evaluated. 

io In this third variant, although the A/D conversion result is 
^ generally read and evaluated later than would actually be 
possible, this delay is generally tolerable. 

3 The complexity that has to be implemented for practical 
J.5 realization of the third variant is undoubtedly the least. 
^ Nevertheless the processing of the interrupt service routine 
whose execution is initiated by the timer interrupt lasts at 
least (i.e. if one instruction is executed per clock cycle and 
if there are no instances of the limit values being exceeded 
20 or undershot by the A/D conversion results, and if there were 
not interrupt latency times) 30 clock cycles. 

If the execution of this application is shifted as far as 
possible into the SLE layer 12, then it can be carried out 
25 considerably faster. 
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The logic block which is shown in Fig. 4 and described with 
reference thereto should then be configured, for example, in 
such a way that the structure shown in Fig. 5 is produced. 

5 The input signals of the arrangement shown in Fig. 5 are the 
A/D conversion results of the A/D converter 15, which are 
designated by ad[0..7], and also the pulses of the timer 17, 
which are designated by Start_T. 

^0 The structurable elements of the logic block in accordance 
f with Fig. 5 are conFig.d in such a way that said logic block, 
:1 in the event of the limit values being exceeded or undershot 

by the A/D conversion results and when the end of the 
Ij measurement series is reached, sends interrupt requests 
115 designated by Irq_Con and, for the purpose of storing the A/D 
^ conversion results together with the counting marker, injects 

corresponding instructions into the instruction pipeline of 

the i^P core. In this case, it is incumbent 

20 ■ upon the second sub-block 6 to effect central sequence 
control within the relevant logic block, 

■ upon the first sub-block 5 to effect comparison of the A/D 
conversion data ad[0..7] received from the A/D converter 15 
25 with values u[0..7] (upper limit value) and 1[0..7] (lower 
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limit value) stored in the constant register 53, and to 
effect generation of the interrupt requests Irq_Con, 

■ upon the third sub-block 7 to effect comparison of addresses 
(for the purpose of completing the instructions to be 
injected and for the purpose of determining the end of the 
measurement series) , and 

■ upon the fourth sub-block 8 to effect generation and/or 
compilation and injection of the instructions to be 
injected. 

In this case, the structurable logic arrangements 61 and 62 
are configured in such a way that they generate output signals 
Irq_Gen, Inj ect_l , Inject_2, New__Adr and Read on the basis of 
input signals MClk, Start_T, End_Of_Adr and Reset using 
internal signals SO, SI, S2 and End_Reached, as defined by the 
Boolean equations below: 

In the structurable logic arrangement 61: 

50 = /S2 * /so * Start_T * /End_Reached + 

/S2 * SI * /SO * /End_Reached; 

51 = /S2 * /SI * SO * /End_Reached + 

/S2 * SI * /SO * /End_Reached; 

52 = /S2 * SI * SO; 
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50. CLK = MClk; /* Clocking with MClk */ 

51. CLK = MClk; /* Clocking with MClk */ 

52. CLK = MClk; /* Clocking with MClk */ 

/* This describes the pass through 5 states, triggered by 
5 Start_T */ 

End^Reached = End__Of_Adr + End_Reached * /Reset; 
End__Reached.CLK = MClk; /* Clocking with MClk */ 

/* Stored End-Flag */ 

\0 

: In the structurable logic arrangement 62 : 



New_Adr = /S2 * SI * /SO + /S2 * SI * SO; 
/* Signal for state 2 and 3 */ 

Inject_l = /S2 * SI * /SO; 

/* Injection 1. Move instruction */ 



Inject_2 = /S2 * SI * SO; 
20 /* Injection 2. Move instruction */ 



Read = /S2 * /SI * SO; 

/* Triggering of the read operation */ 

2 5 Irq_Gen = End_Reached; 

/* Triggering interrupt request at end */ 
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The structurable logic arrangements 54 and 55 are configured 
in such a way that they generate output signals Irq_Conl, 
Irq_Con2, b_ad[0..7] on the basis of input signals ad[0..7], 
5 u[0..7], 1[0..7], Read, Irq_Gen using internal signals 
tmp_upper [0..3], tmp_lower [0 . . 3 ] , tmp_eq[0..3] (for 
intermediate results), tmp_ad[0..7] (for buffer-storage after 
interrogation) and Irq__Tmpl (for IRQ generation and resetting) 
as defined by the Boolean equations below: 

fflo 

In the structurable logic arrangement 54: 

tmp_upper[z] = /u[2z + l] * ad[2z + l] + 
Ti u[2z + l] * ad[2z + l] * /u[2z] * ad[2z] + 

is u[2z + l] * ad[2z + l] * /u [2z] * ad[2z]; 

^ tmp_lower[z] - l[2z + l] * /ad[2z + l] + 

l[2z + l] * /ad[2z+l] l[2z] * /ad[2z] 
/l[2z + l] * /ad[2z + l] l[2z] * /ad[2z]; 
tmp_eq[z] = u[2z+l] * ad[2z + l] * u[2z] * ad[2z..+ 
20 u[2z+l] * ad[2z+l] * /u[2z] * ad[2z] + 

/u[2z + l] * ad[2z + l] * u[2z] * ad[2z.,+ 
/u[2z + l] * /ad[2z + l] * /u[2z] * /ad[2z]; 

/* z runs from 0 to 3 , comparison for larger/smaller and 
25 equality */ 
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tmp_upper [z] . CLK = /Read; /* clocking at read-out end */ 
tmp__lower [z] .CLK = /Read; /* clocking at read-out end */ 
tmp_eq[z] .CLK = /Read; /* clocking at read-out end */ 



tmp_ad[x] - ad[x] /* x from 0 7 */ 

trrp_ad[x] .CLK = /Read; /* clocking at read-out end */ 



lrq_Tmpl = 1; 

lrq_Tmpl . CLK = Irq_Gen; /* clocking with Irq__Gen */ 
Do Irq_Tmpl.AR = IrqlReset; /* reset with IrqlReset */ 

^ /* Generating IRQ for take-up end */ 

In the structurable logic arrangement 55: 

Irq_Conl = Irq_Tmpl; 
=^ /* IRQ is generated for take-up end */ 



Irq_Con2 = tnp_upper[3] + tTrp_tmp[3] * tmp__upper [2 ] 4 

tiTp_eq[3] * tTTp_eq[2] * tTTp_upper [1] + 
2 0 tTTnp_eq[3] + tnp_eq[2] * tTrp_eq[l] * 

tnp_upper[0] + 

/* Overflow */ 

tmp_lower[3] + tnp_eq[3] * tmp__lower [2] + 
tmp_eq[3] * trTp_eq[2] * trrp_lower [1] + 
2 5 tTTp_eq[3] * tinnp_eq[2] * trrp_eq[l] * 

tmp_lower[0] ; 
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/* Underflow */ 
b_ad[y] trrp_ad[y] /* y runs from 0 . . 7 

The structurable logic arrangements 74 and 75 are configured 
in such a way that they generate output signals End__Adr and 
BA[0..15] on the basis of input signals A[0..15], EA[0..15] 
using internal signals temp [0.. 7] as defined by the Boolean 
equations below: 



In the structural logic arrangement 74: 



temp[x] = /A[2x] * /EA[2x] * /A[2x+1] * /EA[2x+l] + 

A[2x] * /EA[2x] * /A[2x+1] * /EA[2x+l] + 

A[2x] * /EA[2x] * A[2x-t-l] * EA[2x+l] + 

A[2x] * EA[2x] * A[2x+1] * EA[2x+l]; 

/* X runs from 0 to 7 , comparison for equality */ 



In the structurable logic arrangement 75: 



End_Adr = temp[0] * temp[l] * temp [2] * temp [3] * 

temp [4] * temp [5] * temp [6] * temp [7] ; 
/* produces 1 if addresses and comparison address 
identical */ 



BA [y] = A [y] ; 



/* y runs from 0 . . 15 */ 
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The structurable logic arrangement 82 is configured in such a 
way that it generates output signals Inject and MP[0..31] 
(assuming 32-bit interface to the |aP core) on the basis of 
input signals Inject_l, Inject_2, BA[0.,15], b_ad[0..7], and 
CR4[0..15] and defined by the Boolean equations below: 

Inject = Inject_l + Inject_2; 
MP[0..15] = CR4[0..15] * Inject_l + 

CR4 [0. .15] * lnject_2; 
/* the 16-bit instruction code stored */ 
/* in CR4[0..15] is communicated */ 
MP[16..23] = BA[0..7] * Inject_l + 

b_ad[0..7] * Inject_2; 
MP[24..31] = BA[8..15] * Inject^l; 
/* the operand or operands 
/* {16-bit address or 8-bit AD value) */ 
/* are communicated 

As is apparent from the explanations above, each time a/D 
conversion data from the A/D converter are read out and 
processed, the arrangement in accordance with Fig. 5 passes 
through four states, namely: 

1) Reading of the A/D conversion result ad[0..7] from the A/D 
converter with automatic restart of the A/D converter. 
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2) The A/D conversion result is processed, i.e. the A/D 
conversion result is compared with an upper limit value 
u[0..7] stored in the constant memory 53 and a lower limit 
value 1[0..7] likewise stored in the constant memory. At 
the same time, a first move instruction is injected into 
the pipeline of the |liP core. 

3) A second move instruction is injected. This instruction 
comprises a transfer of the A/D conversion result to the 
address that has been incremented in the meantime. If the 
A/D conversion result lies outside the range defined by the 
limit values, an interrupt request is simultaneously 
triggered. 

4) The end of the 2048 conversions is possibly reached. In 
this case, a flag is set which prevents further reading-out 
and processing of A/D conversion results. Furthermore, a 
further interrupt request is triggered for the purpose of 
signaling the end of the routine. 

If it assumed that each state requires precisely one sequence 
clock signal, then 4 clock signals are required for each 
instance of reading out and processing A/D conversion data 
from the A/D converter; the )a,P core is temporarily burdened by 
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two or three CPU clock cycles through the injected 
instructions . 

With incorporation of the SLE layer 12, the reading and 
5 evaluation of a/D conversion results considered in the present 
case can be carried out in a small fraction of the time which 
would be necessary if the procedure were as it has been 
heretofore, that is to say if the complete sequence control 
and data processing were essentially left exclusively to the 

3.0 |aP core 11. 

li It goes without saying that similar advantages can also be 

obtained in conjunction with completely different applications 
J from the example described above. 

yi5 

As a result, the program-controlled unit described can be used 
optimally in each case for a large number of highly varied 
applications . 
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